Program Status Word

- The program status word (PSW)
   register, also referred to as the *flag* register, is an 8 bit register
  - Only 6 bits are used
    - These four are CY (carry), AC (auxiliary carry), P (parity), and OV (overflow)
      - They are called *conditional flags*, meaning that they indicate some conditions that resulted after an instruction was executed
    - The PSW3 and PSW4 are designed as RS0 and RS1, and are used to change the bank
  - > The two unused bits are user-definable

Program Status Word (cont')

The result of signed number operation is too large, causing the high-order bit to overflow into the sign bit

| СУ                                                                             | AÇ          | F0                                        | RS1       | RS0      | OV                    |          | Р      | ]      |
|--------------------------------------------------------------------------------|-------------|-------------------------------------------|-----------|----------|-----------------------|----------|--------|--------|
| CY PSV                                                                         | V.7         | Carry flag.                               |           |          | A carry from D3 to D4 |          |        |        |
| AC PSV                                                                         | V.6         | Auxilia                                   | ry carry  | flag.    | Carry                 | out fro  | m the  | d7 bit |
| PSV                                                                            | W.5         | Availab                                   | ole to th | e user f | or gene               | ral purp | ose    |        |
| RS1 PSV                                                                        | W.4         | Registe                                   | r Bank    | selecto  | r bit 1.              |          |        |        |
| RS0 PSV                                                                        | W.3         | Registe                                   | r Bank    | selecto  | r bit 0.              |          |        |        |
| OV PSV                                                                         | V.2         | Overflo                                   | w flag.   | T        | Reflect 1             | the num  | her of | 10     |
| / PSV                                                                          | <b>V</b> .1 | User de                                   | finable   | 1 .      | n regist              |          |        | 13     |
| P PSV                                                                          | W.0         | Parity flag. Set/cleared by hardware each |           |          |                       |          |        |        |
| instruction cycle to indicate an odd/even number of 1 bits in the accumulator. |             |                                           |           |          |                       |          |        |        |

| RS0 | Register Bank    | Address                               |
|-----|------------------|---------------------------------------|
| 0   | 0                | 00H – 07H                             |
| 1   | 1                | 08H – 0FH                             |
| 0   | 2                | 10H – 17H                             |
| 1   | 3                | 18H – 1FH                             |
|     | 0<br>1<br>0<br>1 | RSO Register Bank  0 0  1 1  0 2  1 3 |



ADD Instruction And PSW

## Instructions that affect flag bits

| Instruction | CY | OV | AC |
|-------------|----|----|----|
| ADD         | Х  | Х  | Χ  |
| ADDC        | Х  | Х  | Χ  |
| SUBB        | Х  | Χ  | Χ  |
| MUL         | 0  | Х  |    |
| DIV         | 0  | Χ  |    |
| DA          | Х  |    |    |
| RPC         | Χ  |    |    |
| PLC         | Х  |    |    |
| SETB C      | 1  |    |    |
| CLR C       | 0  |    |    |
| CPL C       | Χ  |    |    |
| ANL C, bit  | Χ  |    |    |
| ANL C, /bit | Χ  |    |    |
| ORL C, bit  | Χ  |    |    |
| ORL C, /bit | Х  |    |    |
| MOV C, bit  | Χ  |    |    |
| CJNE        | Χ  |    |    |



ADD Instruction And PSW (cont')

# The flag bits affected by the ADD instruction are CY, P, AC, and OV

## Example 2-2

Show the status of the CY, AC and P flag after the addition of 38H and 2FH in the following instructions.

#### **Solution:**

$$+2F$$
 00101111

CY = 0 since there is no carry beyond the D7 bit

AC = 1 since there is a carry from the D3 to the D4 bi

P = 1 since the accumulator has an odd number of 1s (it has five 1s)



ADD Instruction And PSW (cont')

## Example 2-3

Show the status of the CY, AC and P flag after the addition of 9CH and 64H in the following instructions.

#### **Solution:**

CY = 1 since there is a carry beyond the D7 bit

AC = 1 since there is a carry from the D3 to the D4 bi

P = 0 since the accumulator has an even number of 1s (it has zero 1s)



ADD Instruction And PSW (cont')

## Example 2-4

Show the status of the CY, AC and P flag after the addition of 88H and 93H in the following instructions.

#### **Solution:**

11B 00011011

CY = 1 since there is a carry beyond the D7 bit

AC = 0 since there is no carry from the D3 to the D4 bi

P = 0 since the accumulator has an even number of 1s (it has four 1s)

